<template>
  <div class="user">
    <!--搜索表单-->
    <div class="common-seach-wrap fr">
      <el-form
        size="small"
        :inline="true"
        :model="formInline"
        class="demo-form-inline"
      >
        <el-form-item label="">
          <el-input
            v-model="formInline.userMobile"
            placeholder="请输入手机号"
          ></el-input>
        </el-form-item>
        <el-form-item label="">
          <el-input
            v-model="formInline.couponId"
            placeholder="请输入优惠券ID"
          ></el-input>
        </el-form-item>
        <el-form-item>
          <el-button type="primary" icon="Search" @click="onSubmit"
            >查询</el-button
          >
          <el-button type="warning" @click="onExport" :loading="exportLoading"
            >导出</el-button
          >
        </el-form-item>
      </el-form>
    </div>

    <div class="product-content">
      <el-form ref="form" :model="form" label-width="100px">
        <div class="table-wrap">
          <el-table
            size="small"
            :data="tableData"
            border
            style="width: 100%"
            v-loading="loading"
          >
            <el-table-column prop="nickName" label="用户"></el-table-column>
            <el-table-column prop="userMobile" label="手机号"></el-table-column>
            <el-table-column prop="couponId" label="优惠券ID"></el-table-column>
            <el-table-column prop="name" label="优惠券名称"></el-table-column>
            <el-table-column prop="couponType" label="优惠券类型">
              <template #default="{ row }">
                <el-col v-if="row.couponType == 10">满减券</el-col>
                <el-col v-else>折扣券</el-col>
              </template>
            </el-table-column>

            <el-table-column
              prop="minPrice"
              label="最低消费金额"
            ></el-table-column>
            <el-table-column prop="seckillStock" label="优惠方式">
              <template #default="scope">
                <div v-if="scope.row.couponType == 10">
                  <span
                    >立减
                    <strong class="orange">{{ scope.row.reducePrice }}</strong>
                    元</span
                  >
                </div>
                <div v-if="scope.row.couponType == 20">
                  <span
                    >打
                    <strong class="orange">{{ scope.row.discount }}</strong>
                    折</span
                  >
                </div>
              </template>
            </el-table-column>
            <el-table-column prop="seckill_stock" label="有效期">
              <template #default="scope">
                <div v-if="scope.row.expireType == 10">
                  <span
                    >领取
                    <strong class="orange">{{ scope.row.expireDay }}</strong>
                    天内有效</span
                  >
                </div>
                <div v-if="scope.row.expireType == 20">
                  <span>
                    {{ scope.row.startTimeText }}
                    ~
                    {{ scope.row.endTimeText }}
                  </span>
                </div>
              </template>
            </el-table-column>
            <el-table-column
              prop="createTime"
              label="领取时间"
            ></el-table-column>
            <el-table-column prop="updateTime" label="使用时间">
              <template #default="scope">
                {{ scope.row.isUse === 1 ? scope.row.updateTime : "-" }}
              </template>
            </el-table-column>
          </el-table>
        </div>
      </el-form>
      <!--分页-->
      <div class="pagination">
        <el-pagination
          @size-change="handleSizeChange"
          @current-change="handleCurrentChange"
          background
          :current-page="curPage"
          :page-size="pageSize"
          layout="total, prev, pager, next, jumper"
          :total="totalDataNumber"
        >
        </el-pagination>
      </div>
    </div>
  </div>
</template>
<script>
import CouponApi from "@/api/coupon.js";
import { useUserStore } from "@/store";
import qs from "qs";
const { token } = useUserStore();

export default {
  data() {
    return {
      token,
      exportLoading: false,
      formInline: {
        userMobile: "",
        couponId: "",
      },
      form: {},
      tableData: [],
      /*一页多少条*/
      pageSize: 20,
      /*一共多少条数据*/
      totalDataNumber: 0,
      /*当前是第几页*/
      curPage: 1,
      /*是否加载完成*/
      loading: true,
    };
  },
  created() {
    /*获取列表*/
    this.getData();
  },
  methods: {
    onSubmit() {
      this.curPage = 1;
      this.getData();
    } /*获取列表*/,
    getData() {
      let self = this;
      let Params = this.formInline;
      Params.pageIndex = self.curPage;
      Params.pageSize = self.pageSize;
      CouponApi.receiveList(Params, true)
        .then((res) => {
          self.loading = false;
          self.tableData = res.data.records;
          self.totalDataNumber = res.data.total;
        })
        .catch((error) => {});
    },
    /*选择第几页*/
    handleCurrentChange(val) {
      let self = this;
      self.curPage = val;
      self.loading = true;
      self.getData();
    },

    async onExport() {
      let Params = this.formInline;
      Params.pageIndex = 1;
      Params.pageSize = 999999;
      Params.tokenshop = this.token;
      let baseUrl = import.meta.env.VITE_BASIC_URL;
      if (!baseUrl) {
        baseUrl = window.location.protocol + "//" + window.location.host;
      }
      this.exportLoading = true;
      //let baseUrl = "http://127.0.0.1:8890";
      window.location.href =
        baseUrl +
        "/api/shop/plus/coupon/coupon/exportReceive?" +
        qs.stringify(Params);
      this.exportLoading = false;
    },

    /*每页多少条*/
    handleSizeChange(val) {
      this.curPage = 1;
      this.pageSize = val;
      this.getData();
    },
  },
};
</script>

<style></style>
